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(57) Abstract: Generating a price schedule involves generating a graph (50) having paths that include states (52) with values (54, 56, 
58). The graph (50) is generated by determining the values (56, 58) of a successor state (52) from the values (56, 58) of a predecessor 
states (52). An optimal path is selected, and a price schedule is determined from the optimal path. Computing an elasticity curve 
involves having a demand model, values for demand model, and filter sets that restrict the values. Elasticity curves arc determined 
by filtering the values using filter sets, and calculating the elasticity curve using the demand model. An best-fitting elasticity curve 
is selected. Adjusting a demand forecast value (56) includes estimating an inventory and a demand at a number of locations (24). 
An expected number of unrealized sales al each location (24) is calculated. An sales forecast value (56) is determined according to 
the expected number. 
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GENERATING AN OPTIMIZED 
PRICE SCHEDULE FOR A PRODUCT 

TECHNICAL FIELD OF THE INVENTION 

This invention relates in general to commercial environments, and more 
particularly to generating an optimized price schedule for a product. 

5 BACKGROUND OF THE INVENTION 

An important decision for a business to make is determining the prices of 
products, goods, or services offered by the business. Pricing decisions are important 
to a business's success or failure, since these decisions may have a critical impact on 
customer demand, profitability, and business operations. Informed pricing decisions, 

10 however, may be difficult to make, since these decisions may need to reflect a large 
number of business objectives and operating constraints, and may need to be made for 
a large number of items across a large number of sales locations. Moreover, pricing 
decisions may need to be frequently updated in order to adjust for rapid changes in 
business conditions, such as changes in inventory, demand, or a competitors prices. 

15 Consequently, businesses may benefit greatly from price optimization, which may 
allow businesses to make effective pricing decisions. 

A business may generate a price schedule over a time horizon, and may 
optimize the price schedule in order to maximize the benefit of a product to the 
business. For example, a price schedule may be optimized to maximize expected 

20 profits or revenues over a time horizon, subject to operating constraints such as an 
allowed frequency of price changes, a maximum number of price changes, or an 
inventory target level. Optimizing price schedules, however, may be computationally 
difficult. As a result, previous techniques for generating an optimized price schedule 
have been inadequate. 

25 
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SUMMARY OF THE INVENTION 

In accordance with the present invention, disadvantages and problems 
associated with generating price schedules have been substantially reduced or 
eliminated. 

5 In accordance with an embodiment of the present invention, a method for 

generating a price schedule includes generating a transition graph having paths. Each 
path has states, and each state has a price value, an inventory value, and a state value. 
The transition graph is generated by repeating the following for a number of stages 
until a last stage is reached. The price value of a successor state is determined. The 

10 inventory value of the successor state is calculated using the price value and the 
inventory value of a predecessor state. The state value of the successor state is 
calculated using the price value and the inventory value of the predecessor state. 
After the last stage has been reached, an optimal path is selected according to the state 
values of the states, and a price schedule is determined from the optimal path. 

15 In. accordance with another embodiment of the present invention, a method for 

computing an elasticity curve includes selecting a demand model having a number of 
variables. A number of values for each variable are received. Filter sets that restrict 
the values for at least one variable are defined. An elasticity curve is determined for 
each filter set by filtering the values for at least one variable using the filter set, and 

20 calculating the elasticity curve from the filtered values by performing a regression 
analysis using the demand model as a regression equation. A quality value is 
measured for each elasticity curve, and an optimal elasticity curve is selected 
according to the quality values. 

In accordance with another embodiment of the present invention, a method for 

25 determining a sales forecast from an estimated demand and inventory includes 
defining a number of locations. An inventory and a demand are estimated at each 
location. An expected number of unrealized sales at each location is calculated using a 
difference between the demand and the inventory at the location. A sales forecast is 
determined using the expected number of unrealized sales. 

30 Certain embodiments of the present invention may provide one or more 

technical advantages over previous price scheduling techniques. Selling goods 
typically requires dynamic adjustment of a sales price over a time horizon. Given a 
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forecast of product demand over time and a model of price elasticity, the present 
invention may calculate a price schedule that maximizes a business objective such as 
cumulative revenue, while satisfying business constraints such as a desired price 
behavior or an inventory target level. 
5 The present invention may generate price schedules that satisfy a variety of 

operating constraints. Price schedules are typically required to meet operating 
constraints such as a maximum number of price changes within a given time period of 
a time horizon, a maximum number of price changes over a time horizon, or a 
maximum price change over a time horizon. Price values may be constrained to meet 

10 specific price rules, for example, a price value must have a "9" in the cents position. 
Price values may be constrained to adhere to certain price reduction levels, such as 
25%, 50%, or 75% off a base price. Constraints may be applied to the inventory age 
as described by the time the products are stored in inventory. The present invention 
may generate price schedules that satisfy these and other operating constraints. 

15 The present invention may allow for optimization of a variety of business 

objectives. Objectives may include, but are not limited to, margin and revenue 
considerations, opportunity costs of capital, inventory carrying costs, inventory age, 
costs of implementing price changes, impact on profits of substitute products, or 
opportunity costs of allocated shelf-space, or any other suitable objective. 

20 The present invention may be extended to incorporate an uncertainty of a 

demand forecast or an elasticity model in order to achieve certain statistical 
guarantees of performance of computed price schedules. The invention may be 
extended to compute price schedules of portfolios of products while considering price 
constraints between these products, or price schedules for groups of locations given 

25 price constraints between locations in the group. 

The present invention may efficiently generate an optimized price schedule 
using a "quantized dynamic programming 11 technique. A transition graph with paths 
representing possible price schedules may be generated using quantized dynamic 
programming. An optimal path of the transition graph is selected in order to 

30 determine an optimized price schedule. The present invention may improve the 
efficiency of the optimization by quantizing values associated with the transition 
graph at various degrees of granularity. Quantizing the state values reduces the size 
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of transition graph, which may improve the processing time and power required to 
determine an optimal path of the transition graph. 

The present invention may take into account the elasticity of a product in order 
to improve the accuracy of the optimization. The elasticity of a product describes a 
5 change in the demand of a product in response to a change in the price of the product. 
The present invention may take into account the effect of unrealized sales due. to 
supply limitations, which may improve the accuracy of the optimal path. An 
unrealized sale is predicted where there is a demand for a product, but no inventory, 
and may result when inventory is distributed across a group of locations that are being 

10 optimized together. Typically, aggregate values only take into account a total demand 
and a total inventory and do not account for supply limitations. 

The present invention may be used to compute an optimal sequence of product 
markdowns for liquidating merchandise, which may enable sellers to better plan and 
more profitably manage inventory, such as at the end of a product lifecycle. Given 

15 initial inventory and price values, a price schedule of product markdowns that 
maximizes business objectives while satisfying business constraints may be 
calculated. The price schedule may be used to maximize margin capture rates while 
reducing margin degradation and to provide accurate estimates of both margin capture 
rates and margin degradation factors. In addition, the present invention may be used to 

20 determine optimal start and end dates of a markdown horizon, or to determine which 
products should be put on a markdown plan. The present invention may be used to 
guide the decision of how many units of which product should be acquired for 
subsequent sale. 

Systems and methods incorporating one or more of these or other advantages 
25 may be well suited for modern commercial environments such as those associated 
with marking down the price of a product to achieve a predetermined inventory target. 
Other technical advantages are readily apparent to those skilled in the art from the 
following figures, descriptions, and claims. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

For a more complete understanding of the present invention and its 
advantages, reference is now made to the following description, taken in conjunction 
with the accompanying drawings, in which: 
5 . FIGURE 1 illustrates an example system for generating an optimized price 

schedule for a product; 

FIGURE 2 illustrates an example transition graph that represents possible 
valid price schedules for a product; 

FIGURE 3 illustrates an example method for generating an optimized price 
10 schedule for a product; 

FIGURE 4 illustrates an example method for computing elasticity; 

FIGURE 5 illustrates an example method for optimizing a transition graph to 
generate an optimized price schedule for a product; 

FIGURES 6A through 6C illustrate example an elasticity curve; and 
15 FIGURE 7 illustrates an example method for adjusting an aggregate inventory 

value. 

DETAILED DESCRIPTION OF THE INVENTION 

FIGURE 1 illustrates an example system 10 that generates an optimized price 
20 schedule for a product. A price schedule lists prices for a product at successive stages 
of time. A company 20 may use system 10 to determine an optimized price schedule 
for a product sold by company 20. Depending on the nature of company 20, company 
20 may include any combination of locations 24, for example, one or more sales 
locations 24. 

25 Company 20 and/or one or more locations 24 may include a computer system 

26 that may share data storage, communications, or other resources according to 
particular needs. Computer systems 26 may include appropriate input devices, output 
devices, mass storage media, processors, memory, or other components for receiving, 
processing, storing, and communicating information according to the operation of 

30 system 10. As used in this document, the term "computer" is intended to encompass a 
personal computer, work station, network computer, wireless data port, wireless 
telephone, personal digital assistant, one or more microprocessors within these or 
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other devices, or any other suitable processing device. Reference herein to a location 
24 may include reference to one or more associated computing devices and/or 
persons, as appropriate. 

A server 30 manages applications that generate an optimized price schedule. 
5 Server 30 includes an optimizer 34 and an elasticity module 36. Optimizer includes a 
transition graph generator 32 and a forecast correction module 35. Transition graph 
generator 32 may be used to generate a transition graph that represents possible price 
schedules that satisfy predetermined business constraints. Optimizer 34 optimizes the 
transition graph generated by transition graph generator 32 in order to determine an 

10 optimal path of the transition graph. The optimal path represents an optimal price 
schedule. Forecast correction module 35 determines a projected number of unrealized 
sales, and converts a demand forecast into a sales forecast. Elasticity module 36 may 
be used to determine a projected price elasticity curve that transition graph generator 
32 may use to generate a transition graph. 

15 A database 40 stores data that may be used by server 30. History 42 may 

include data that may be used to generate a price schedule for a product, such as 
inventory history or sales history of one or more products. History 42 may include, 
for example, a number of units of a product sold, a price per unit, and a time at which 
the units were sold. Elasticity curve 44 describes an estimated change in demand for 

20 a product in response to a change of a price of the product. Demand forecast 43 
describes a forecasted demand over time. Transition graph generator 32 uses elasticity 
curve 44 to determine an estimated change in the demand of a product in response to a 
change in the price of the product. 

Locations 24 and/or database 40 may be coupled to server 30 using one or 

25 more local area networks (LANs), metropolitan area networks (MANs), wide area 
networks (WANs), a global computer network such as the Internet, or any other 
appropriate wire line, wireless, or other links. 

FIGURE 2 illustrates an example transition graph 50 that represents possible 
price schedules. Transition graph 50 includes states 52 at different stages 60. Stages 

30 60 represent time intervals during which a product has a particular price. Stages 60 
may represent any suitable time interval, for example, a week. Additionally, the time 
intervals represented by stages 60 may be equal to each other in length or may differ 
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from each other, for example, using telescoping buffers. In the illustrated example, 
n stages 60 are illustrated. A predecessor state may be coupled to a successor state by 
a transition 53. A sequence of states 52 from stage 1 60a to stage n 60n coupled by 
transitions 53 form a path of transition graph 50. 
5 A state 52 may include any combination of values, for example, a stage value 

51, a price value 54, an inventory value 56, a state value 58, and a state history 59. 
Stage value 51 represents the number of the stage 60 at which state 52 occurs. Price 
value 54 represents the price per unit of a product. Price value 54 may alternatively 
be associated with a transition 53 from a predecessor state to a successor state. 
10 Inventory value 56 represents the number of units of the product in the inventory of 
company 20, typically at the beginning of the state following transactions at previous 
states. 

State value 58 represents the value of state 52, and is used to calculate the 
value of the paths of transition graph 50. State value 58 may be computed from, for 

15 example, the sales of a product, the expected profit of a product, the gross margin of a 
product, the inventory carrying cost of an optimal path leading to the state, the 
number of price changes of an optimal path leading to the state, or the average selling 
price of a product. State history 59 of state 52 includes information associated with a 
path from the initial state to state 52. For example, state history 59 may include a 

20 number of price changes since stage 60a or a number of stages since a last price 
change. State history 59 may include a certainty value that measures the certainty of 
state value 58. The certainty value may be determined from an error margin 
associated with the calculation of state value 58. 

In the illustrated example, transition graph 50 includes state 52a at stage 60a. 

25 State 52a has a price value 54 of "$100.00," an inventory value 56 of "500 units", a 
state value 58 of "0" (since state 52a is an initial state), and a state history 59 h. State 
52a is a predecessor state to successor states 52b-e. Successor states 52b-e represent 
possible states at stage 60b given state 52a at stage 60a. States 52b-e include price 
values "$100.00," "$95.00," "$90.00," and "$85.00," respectively. These price values 

30 54 represent possible prices of the product at stage 60b given that the product has a 
price value of $100.00 at stage 60a. Inventory values 56 of "400 units" for states 52b- 
e represent the number of units at stage 60b given that there were five hundred units 
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with a price value of $100.00 per unit at stage 60a. Inventory value 56 may be 
computed using a demand forecast, and elasticity curve 44 provided by elasticity 
module 36. State values 58 of states 52b-e measure the value of states 52b-e given 
that one hundred units were sold at a price value of $100.00 per unit. 
5 The values 54, 56, 58, and 59 may be quantized to reduce the number of 

successor states 52, which may reduce the complexity of transition graph 50. 
Reducing the complexity of transition graph 50 may in turn reduce the processing 
power and time needed to generate transition graph 50, which may be important if 
transition graph 50 is large. In one embodiment, price value 54 may be quantized. 

10 For example, specific price values 54 may be predetermined for each stage. "Each" as 
used in this document means each member of a set or each member of a subset of a 
set. In the illustrated example, the price values "$100.00", "$95.00," "$90.00," and 
"$80.00" may be predetermined for states 52b-e. Alternatively, changes in the price 
values 54 from one stage 60 to another stage 60 may be predetermined. For example, 

15 price changes of $0.00, -$5.00, -$10.00, and -$15.00 may be predetermined for states 
52b-e. Alternatively, price increments may be predetermined. For example, price 
values at $5.00 increments may be predetermined for states 52b-e. 

Similarly, inventory values 56 may be quantized. Inventory increments may 
be predetermined, and inventory values 56 at a successor stage 60 computed from 

20 price value 54 and an inventory value 56 at a predecessor stage 60 may be rounded up 
or down to the appropriate quantized inventory value 56. For example, an inventory 
increment may be predetermined to be ten units, and inventory values 56 of states 52 
may be rounded up or down to inventory values at increments of ten units. Rounding 
of inventory values, however, is not required to store the states, but may be used to 

25 compare states. 

Additionally, constraints may be used to reduce the number of successor states 
52 generated from a predecessor state 52. Constraints may be placed on price value 
54. For example, a maximum and a minimum price change may be used to limit the 
difference between price values 54 of a successor state 52 and the price values 54 of a 

30 predecessor state 52. In the illustrated example, a maximum price change is -$15.00, 
and no minimum price change is given. An absolute minimum price value 54 and an 
absolute maximum price value 54 may be defined to limit the price value 54 of any 
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state 52. In the illustrated example, a maximum price value is the starting price of 
"$100.00," and a minimum price value is "$50.00." 

A minimum and a maximum number of price changes may be used to control 
the number of times price value 54 may change from stage 60a to stage 60n. 
5 Alternatively, initial maximum and minimum price changes may be used to limit the 
price change from stage 60a to stage 60b, and subsequent maximum and minimum 
price changes may be used to limit price changes from stage 60b to stage 60n. A 
minimum number of stages 60 between price changes may be used to avoid frequent 
price changes. A maximum number of price changes may be defined to limit the 

10 number of price changes from stage 60a to stage 60n. 

Constraints may be placed on inventory values 56. For example, a maximum 
ending inventory may be used to eliminate states 52 at stage 60n that include 
inventory values 56 that are too high. Additionally, constraints may define a penalty 
or cost for inventory left at the last stage 60. Maximum and minimum inventory 

15 values 56 may be used to control the unit's inventory at each stage 52. 

FIGURE 3 illustrates an example method for generating an optimized price 
schedule for a product. At step 78, elasticity module 36 accesses demand forecast 43 
from database 40. At step 80, elasticity module 36 computes an optimal elasticity 
curve 44. Elasticity curve 44 describes the change in the demand for a product in 

20 response to a change in the price of the product. A method for computing elasticity 
curve 44 is described in more detail with reference to FIGURE 5. Demand forecast 
43 is adjusted at step 82. Demand forecast 43 may be adjusted in order to take into 
account unrealized sales that are estimated at one or more sales locations 24. A 
method for adjusting demand forecast 43 is described in more detail with reference to 

25 FIGURE 7. Demand forecast 43 is converted to a sales forecast at step 84. 
Generating an optimized price schedule for locations 24 in the aggregate uses a sales 
forecast. A method for converting demand forecast 43 is described in more detail 
with reference to FIGURE 7. 

The values describing the product are quantized at step 86 to reduce the 

30 complexity of the computation. At step 88, transition graph generator 32 generates a 
transition graph 50 that represents possible price schedules for a product. A method 
for generating transition graph 50 described with reference to FIGURE 4. At step 90, 
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optimizer 34 determines an optimal path of transition graph 50. The optimal path 
represents an optimized price schedule for company 20. Determining an optimal path 
is described in more detail with reference to FIGURE 4. A price schedule is 
determined from the optimal path at step 92. The price schedule is output at step 94. 
5 A computer 26 may output the price schedule. 

FIGURE 4 illustrates an example method for generating an optimized price 
schedule using dynamic programming. Using dynamic programming techniques, a 
transition graph 50 is generated. An optimal path of transition graph 50 is selected to 
determine an optimized price schedule. In one embodiment, a user at location 24 may 

10 use computer 26 to initiate transition graph generator 32, which may in turn use 
elasticity module 36 and optimizer 34 to generate an optimized price schedule. 

Generating a price schedule includes generating transition graph 50 that 
comprises paths. Each path includes states 52, and each state 52 may include, but is 
not limited to, the following: a stage 60 relating to the state's position in the time 

15 horizon, an assigned price, a projected inventory level, a state value, and a record of 
historic information, such as number of previous price changes. The inventory level, 
value, and history of state 52 reflect the best path from the origin of transition graph 
50 that leads to state 52. 

Transition graph 50 may be generated by'repeating the following for a number 

20 of stages 60 until a final stage is reached. The price value of a successor of a current 
state 52 is determined using a forecast of product demand at the current stage 60 and a 
mathematical model of the current stage's price-demand response, also referred to as 
"price-demand elasticity." The process of generating successor states may be called 
"state expansion". The stage 60, inventory level, value, and history of the successor 

25 state 52 are calculated using the current state information in addition to the forecasted 
demand and price-demand elasticity for the current state. The process of state 
expansion may be carried out for states 52 of a given stage, advancing stage 60 by 
stage 60 through the time horizon in order to construct transition graph 50. After the 
final stage 60 has been reached and states 52 have been expanded, an optimal path is 

30 selected according to the state values and other information of states 52. A price 
schedule is determined from the optimal path. 
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At step 150, transition graph generator 32 defines states 52 and transitions 53 
of transition graph 50. States q t may be defined by Equation (6): 



5 where: 

Si represents the stage, 

pi represents the price at stage s/, 

d represents the inventory of state qi 

Vi represents the value of state q 

1 0 hi represents accumulated state history of state qi 



Set Q is defined as the set of all states q x . While the state history may include various 
aspects relating to an optimal path to the state such as a number of price changes, the 
state representation as expressed by Equation (6) abstracts away the details of the 
15 state history. Different representations of a state may be used. Unless otherwise 
noted, the components of a state are labeled using the state's annotation. For example, 
the state q' has components labeled (s\p\c\ v',/i') . 

State value v,- is used to evaluate states qt during state expansion. State value v, 
may represent, for example, revenues accumulated through state q { . Additional or 

20 alternative criteria may be used to select an optimal final state from transition graph 
50. For example, an evaluation function finalval:Q^> R that maps states to real 
numbers may be used to evaluate inventory values and other values of a final state. A 
feasibility function finalfeasible:Q^> {0,1} may be used to determine whether a final 
state is feasible according to the constraints. For example, a feasibility function may 

25 be used to determine whether a final inventory value is acceptable. 

Initial conditions and data are received at step 152. Initial conditions may 
include a maximum number of stages n, an initial state qo, and a maximum number M 
of inventory units allowed at the last stage n. Other constraints may also be included 
in the initial conditions. Initial conditions may also include quantization criteria such 
30 as quantized inventory levels C and quantized price levels P. Quantization of 
inventory and price values may be defined by Equations (7): 

y c :R-*C quantization of inventory (7) 
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y p :R^>P quantization of price 

where R is the set of real numbers. In general, the quantization may be used to limit 
the number of states that may be generated at each stage while constructing the 
5 transition graph. 

Initial data may include a demand forecast F & at a stage s, and an elasticity 
adjustment E(p,s) for price p at stage s that may be used to adjust demand forecast F s . 
Elasticity adjustment E(p,s) may be determined from the elasticity curve calculated by 
elasticity module 36 according to the method as described in connection with 
10 FIGURE 5. For example, an elasticity constant ce may be extracted from the 
elasticity curve, as expressed by Equation (1), and may be used to determine E(p t s). 
If only the effect of price on demand is considered, and if elasticity is assumed to be 
constant over time and given according to the model in Equation (1), E(p t s) may be 
defined using Equation (8): 

15 E(p,s) = ^j (8) 

where: 

ce = elasticity constant 

po = base price on which forecast F s is based 

Transition 53 from a predecessor state 52 to a successor state 52 may be defined by a 
20 state-transition function expressed by Definition (9) that has a state-transition operator 
h-* : 

(s,p,c,v,h) ^(?',p',c',v' l A / ), ifandonlyif (9) 

^' = ^ + 1, 
p'eP, 

25 c' = y c (max(0, c-F r E (p,s))) 9 

v 1 = v+/?.(c-c'), 

h' captures the new state history and modifies h according 

to the transition, and 
the transition to the new state is consistent with any additional 
30 constraints that may be imposed. 

Definition (9) provides an example of a state-transition function. Transition 53, 
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however, may be defined in any suitable manner. In addition, constraints may be 
placed on transition 53 in order to limit the successor states 52 of a state 52. Any of 
the components of state 52 may be constrained. A constraint may, for example, 
prohibit drastic or frequent changes in the price values. A price-adjusted demand 
5 forecast F s -E(p,s) may be adjusted to take into account unrealized sales that occur at 

one or more sales locations 24. A method for adjusting the price-adjusted demand 
forecast is described in more detail in connection with FIGURE 7. 

The following summary outlines a method for determining an optimal final 
state. The method expands transition graph 50 and determines an optimal feasible 
10 final state. An optimized price schedule may be determined from the optimal feasible 
final state and transition graph 50. The subsequent description provides a more 
detailed description of the method. 

Optimal Price Scheduling Algorithm (Summary) 

Input: Stages n, Forecast F St Elasticity E(p,s) t Quantizations Cj p t 
Initial state go 

1 K~{q 0 }, U~Q\ K,F~ {qeU:q Q » q) 

2 for k = 1 to n 

3 S*:={} _ 

4 for each psP 

S* .-=S k Kj{(q*q')eKxF:qeF& 

5 ? ')= awmaxfo : q i f-» q % & 

7 e (cJ=y e (cj} 

6 end 

7 K:=KkjF 

8 Vi=U/F 

9 F .•= {q'<= U : 3q e K : q q'} 

10 end 

Output: argmax,.,..^^,, {fmah>al(q)} , 
Graph U S 1 ) 
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At step 154, data structures that describe transition graph 50 are defined and 
initialized. The data structures may include set K at stage i, which is a set of maximal 
states q that may be coupled by transitions 53 from initial state qo to a state at stage /. 
A maximal state 52 may be calculated according to state value v. Equation (10) 
5 describes a valid invariant for the states in set K: 

Vg = Cj,/?,c,v,A) eK:q = argmax{v*: q 0 H>* q % &q % = (s y p,c\v\h) & 

frQ 0°) 
YcW) = Yc( c )} 

where h->* denotes a possibly repeated application of the state-transition operator , 
as defined by Definition (9). Equation (10) expresses that at any time, set AT contains 
only maximal states, that is, states (s, p, c, v, h) for which there is no better state, 
10 having the same values of s, p, h, and the same quantized value of c, that is reachable 
from qo. 

Initially, set K is defined as {qo} . Set F is a set of successor states 52 that may 
be coupled to a maximal predecessor state 52 of set K. Set U is a set of unexplored 
states 52 at a stage 60, and may be defined by U = (Q\K)\F. Set U may be initialized 
15 as U:=Q\K. Set S is a set of transitions 53 that couple a maximal predecessor state of 
set K to an unexplored successor state 52 of set U. Set S may be initialized as S: = {} . 

Successor states 52 are generated at step 158. Successor states 52 may be 
generated by adding state transitions to the set according to Equation (1 1): 



S k :=S k Kj{(q*,q 1 )eKxF\qeF& 

(q*,?) = argmax {v 2 | q x h> q 2 & 

20 <f..*2)e*xF _ (11) 

q 2 =(k+l,p,c 2 ,v 2f h)& 
^c( c 2) = r c (c)} 



Ordered pair (?*,<j0 is a state-transition to be added, and q is a reachable state of set 
F that conforms to the specific price value p. The argmax expression yields an 
ordered pair (q ♦g')- State q' of the ordered pair represents a value-maximal successor 
25 state q\ given fixed price value p , state history value h , and fixed inventory value 
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c, modulo the given quantization y c > m( * state tf* represents the origin of the 
transition. State q binds inventory value c and state history value h , and enforces 
that only states which equivalent state history values are compared in the arginax 
expression. Set F, set K y and set U % are updated according to Equations (12): 
5 F:={q'eU:3qeK:qh*q'} 
K-K\jF 

U:=U\F (12) 

A successor state 52 may be indexed by its maximal predecessor state 52 in order to 

allow for efficient retrieval of maximal states 52 from previous stages 60. The index 
10 may be implemented in any suitable manner, for example, using a hash function or 

static array indexing. Invalid successor states 52 may be eliminated according to the 

constraints specified in the initial conditions. 

Values for the successor state 52 are quantized and adjusted at step 160. 

Values for successor states 52 may be quantized and adjusted using Equations (7). 
15 Price value p r is quantized according to the quantization criteria specified in the initial 

conditions. Quantizing values reduces the complexity of transition graph 50, which 

may improve the processing time required to determine an optimal path of transition 

graph 50. Inventory c' is also adjusted using the elasticity adjustment E(p,s). 

Inventory c' may also be adjusted in order to take into account unrealized sales that 
20 occur at one or more sales locations 24. A method for adjusting inventory values 56 

is described in more detail in connection with FIGURE 7. 

Quantization may be applied in any suitable manner. For example, price 

values may be stored as quantized values, and inventory values may be stored as exact 

precise values. When different states are compared using Equation (11), the inventory 
25 values may be compared after quantization. If the quantized values are the same, the 

two successors can be regarded identical according to Equation (1 1). 

At step 164, transition graph generator 32 determines whether there is a next 

stage 60. If there is a next stage 60, transition graph generator 32-returns to step 156 

to define successor states 52 at the next stage 60. If there is no next stage 60 at step 
30 164, transition graph generator 32 proceeds to step 166, where optimizer 34 

determines an optimal path of transition graph 50. The optimal path may be 
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determined the at the final stage, which may be described by Equation (14), in terms 
of an optimal feasible solution and a transition graph: 

argmax^^ >fl// ^ /WfU) {^na/va/(^)} , 
5 Graph (K, U S k ) (14) 

The selection of the optimal path may be limited by a constraint specified in the initial 
conditions, which may be labeled as finalfeasible. Additionally or alternatively, a 
predetermined certainty value may limit the optimal paths to paths that satisfy the 

1 0 predetermined certainty value. 

A price schedule is determined from the optimal path at step 168. The path 
comprises a sequence of states 52 that describe a price value at each stage 60. The 
price values at each stage 60 are converted into a price schedule for a product. After 
the price schedule is determined, the method is terminated. A user may program 

15 transition graph generator 32 to periodically perform the method, for example, daily 
or weekly, in order to provide an updated price schedule generated using recent data. 

In one embodiment, the present invention may be used to compute an optimal 
sequence of product markdowns for liquidating merchandise, which may enable 
sellers to better plan and more profitably manage inventory, for example, at the end of 

20 a product lifecycle. Given initial inventory and price values, a price schedule of 
product markdowns that maximizes business objectives while satisfying business 
constraints may be calculated. 

FIGURE 5 illustrates an example method for computing elasticity. In one 
embodiment, a user at location 24 may use computer 26 to initiate elasticity module 

25 36 to compute an elasticity curve 44. According to the method, elasticity module 36 
determines an elasticity curve from state history and may use different filter sets to 
determine the elasticity curve. In general, each filter set is used to filter product data. 
Regression analysis is performed on the filtered data to yield elasticity curves. The fit 
of the data and the elasticity curves is measured, and an elasticity curve is selected. 
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Elasticity module 36 begins at step 110, where a demand model having 
dependent and independent variables is determined. The demand model may be 
defined by, for example, Equation (1): 

5 D = KP c '(! + ayt fi e a (1) 

where: 

D = demand 
P = price 

10 a = promotional variable 

/ = time 

c E = elasticity constant 

K, q, fl and ^are constants, KX), and it is expected that C£<0, />0 9 and ?<0. Equation 
15 (l)maybe rewritten as Equation (2) : 

ln(D) = hi(K) + cln(P) + $ln(l+a) + fin(t) + yt (2) 

Equation (2) may be used as a regression equation, where ln(D) is the dependent 
20 variable and ln(P), ln(l+a), ln(r), and / are the independent variables. 

At step 112, values for the dependent and independent variables are received. 
The values may be derived from data describing one or more products. The products 
may include the product for which a price schedule is to be generated and/or products 
similar to the product for which a price schedule is to be generated. For example, a 
25 single product may not have sufficient sales history data to generate a meaningful 
price schedule, so data from similar products may be combined to generate a price 
schedule. 

Data for a product may be grouped in data rows, where each data row includes 
data for a specific stage in time. A data row may include, for example, the following 
30 values: Product Identifier, Stage Number, Sales, Price, Revenues, and Promo, 
froduct Identifier identifies the product, and Stage Number identifies the stage. Sales 
describes the number of units of the products sold during the stage, Price defines the 
price per unit, and Revenues describe the revenues generated from the sale of the 
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product. Promo describes the number of units sold during a promotion for the 
product, such as a temporary price reduction. Other or additional values may be used 
to calculate an elasticity curve. For example, a seasonal index variable that describes 
how a time of year, such as the Christmas season, affects the demand for a product 
may be used. 

The values for Sales may be used as the values for demand Z>. Values for 
Price and Stage Number may be used as the values for price P and time /. Promotion 
variable a measures the significance of a promotion, and may be defined using 
Equation (3): 



10 a:= 



Promo 

$ a l es 9 if Promo > Promo Filter (3) 
0 otherwise 



where Promo Filter is a constraint. 

Filter sets are defined at step 114. Each filter set comprises one or more 
constraints that restrict the values for the variables of the demand model. An example 
filter set is described by Table 1 : 

TABLE 1 

Example 

Filter Name Description Value 

Min Sales Minimum number of sales 5 units 

20 Min Revenues Minimum revenues $10 

Min Rows Minimum number of data rows 15 points 

Promo Filter Promotions filter , 5% 

Perc Filter Data value filter 2.5% 

25 

According to the filter set of Table 1, a data row is removed if Sales is less than Min 
Sales or Revenues is less than Min Revenues, The data rows for. a product are 
removed if number of data rows for the product is less than Min Rows. Promo Filter 
is used to define promotion variable a, as shown in Equation (3). Data rows that 
30 include values that are within a first or last percentile given by Perc Filter are 
removed. 
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Steps 116 through 144 are performed for each filter set in order to determine 
the filter set that yields an optimal elasticity curve. At step 1 16, a filter set is selected. 
Steps 118 through 136 are performed on data for each product individually in order to 
eliminate unacceptable data. At step 118, a product is selected. At step 120, the 
5 values for the product are filtered using the filter set selected at step 116. The 
variables are normalized at step 122. Variables may be normalized according to 
Equations (4): 

Norm(D) = ln(Z))-Mean(ln(Z))) 
1 0 Norm(P) = ln(P)-Mean(ln(P)) (4) 

Norm(/) = /-Mean(/) 
Norm(ln(/)) = ln(0-Mean(ln(/)) 

where Mean (x) is the average of x. 

15 At step 124, a regression analysis is performed using the demand model, as 

expressed by Equation (2), as the regression equation of the dependent variable over 
the independent variables, that is, of \n(D) over \n(P) 9 ln(l+a), ln(t), and t. The 
regression analysis yields values for coefficients c& K t q, and y 9 which are inserted 
into Equation (2) to define a regression or elasticity curve. The quality of the 

20 elasticity curve is measured at step 126. The quality may be measured by determining 
the fit of the elasticity curve to the values that were used to generate the elasticity 
curve, and may be measured using a Box-Wetz value B expressed by Equation (5): 



B = {maxiYi -min. %)/^~ ) (5) 

25 

where: 

p - number of parameters 
s 2 * V(Yi) 

i 

30 The quality of the elasticity curve is determined to be acceptable or not at step 

128. The quality may be acceptable if it satisfies a predetermined criteria. If the 
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quality is not acceptable, the data for the product is eliminated at step 130, and 
elasticity module 36 proceeds to step 138. If the quality is acceptable, elasticity 
module 36 proceeds to step 132. 

At step 132, an elasticity value is determined from the elasticity curve. The 
5 negative of the elasticity coefficient c E of the price variable P may be. used as the 
elasticity value. In one embodiment, the elasticity value is required to be positive, 
i At step 138, elasticity module 36 determines whether there is a next product. If there 
is a next product, elasticity module 36 returns to step 118, where the next product is 
selected. If there is no next product, elasticity module 36 proceeds to step 140. 

10 Steps 140 through 144 are performed on the aggregated data for the products 

in order to determine which filter set provides an optimized fit of the elasticity curve. 
At step 140, the data for the remaining products are aggregated to yield aggregated 
data. At step 142, regression analysis is performed on the aggregated data. The 
regression analysis may use the demand model as expressed by Equation (2) as the 

15 regression equation of the dependent variable over the independent variables. The 
quality of the elasticity curve is measured at step 144, and may be measured in a 
manner substantially similar to that described above in connection with step 126. 

At step 138, elasticity module 36 determines whether there is a next filter set. 
If there is a next filter set, elasticity module 36 returns to step 116, where the next * 

20 - filter set is selected. If there is no next filter set, elasticity module 36 proceeds to step 
148, where an optimal elasticity curve is selected. The optimal elasticity curve may 
be the highest quality elasticity curve according to measurements performed at step 
144. Additionally, the elasticity curve may be rewritten in the format of Equation (1) 
and sent to transition graph generator 32. After selecting the optimal elasticity curve, 

25 elasticity module 36 terminates the method. A user may program elasticity module 36 
to perform the method periodically, for example, daily or weekly, in order to provide 
an updated elasticity curve to transition graph generator 32. 

FIGURES 6A through 6C illustrate an example elasticity curve 40. FIGURE 
6A illustrates elasticity curve 40 with respect to time. Elasticity curve 40 is computed 

30 from price values and demand values. FIGURE 6B illustrates elasticity curve 40 and 
the demand values with respect to time. FIGURE 6C illustrates elasticity curve 40 and 
the demand values with respect to the price values. 
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FIGURE 7 illustrates an example method for estimating a sales forecast from a 
demand forecast and an aggregate inventory value that describes the total inventory 
spread across a number of locations 24 of company 20. A demand forecast typically 
predicts customer demand, but not sales. Computing an optimized price schedule for a 
5 number of locations 24 in the aggregate, however, requires the prediction of sales 
instead of demand. An aggregate sales forecast may be calculated from the aggregate 
inventory value and demand values from predecessor states 52. 

Unrealized sales, or stockouts, may be determined in order to predict sales. 
An unrealized sale is predicted where there is a demand at a location, but no 

10 inventory. An unrealized sale may be expressed as a difference between a demand 
value and an inventory value at any given location 24. According to the method, a 
demand forecast is adjusted to take into account unrealized sales that may be 
predicted at one or more locations 24 of company 20, which may improve the 
accuracy of the predicted inventory values of an optimized price schedule. 

15 The method performs a significant adjustment to the demand forecast when 

inventory levels and forecasted demands are aggregated across a number of locations 
24, or a store-group. The method may be used with the method for generating an 
optimized price schedule as described with reference to FIGURE 4, in order to 
improve the accuracy of the predicted number of sales when operating on a store- 

20 group level The method may be used at each state-expansion in order to estimate the 
unit sales from the demand forecast, thereby significantly improving the accuracy of 
the inventory level of a successor state, in particular at low inventory levels. The 
method may be calibrated to a particular location 24 and replenishment situation 
based on historic sales and inventory figures. 

25 This method may be applied as part of the computation of the optimal price 

schedule, particularly if the estimate is not accurately performed as a preprocessing 
step. This may be the case if the demand value at each stage of the price scheduling 
horizon is dependent on a price value, and the future inventory values are dependent 
on the demand value. As has been outlined above, the prediction of sales in turn 

30 depends on the inventory values, leading to a circular dependency. The circular 
dependency may be resolved by taking the effect of distributed inventory on projected 
sales into account at each step of the computation of a price schedule. FIGURE 7 



WO 02/29696 



PCT/US01/31723 



22 



describes how a projected number of sales can be computed, given a demand forecast 
and an aggregate inventory at locations 24. 

At step 180, transition graph generator 32 defines a number n of locations 24. 
An inventory s at each location 24 is estimated at step 182. Inventory s may be 
5 estimated by, for example, randomly populating each location 24 with inventory units. 
A demand at d at each location 24 is estimated at step 184. Demand d at each location 
24 may be estimated by randomly populating each location 24 with demand units. 
This random sampling may be performed a number of times. The expected number 
E(M) of unrealized sales is determined at step 186. 

10 Alternatively, steps 182 through 186 may be performed using a probabilistic 

estimation. Given S units that are assumed to be evenly distributed across a number 
of n locations, the probability of a location receiving s units may be expressed using a 
binomial distribution. The binomial distribution may be used to determine the 
probability of s successful experiments, where the probability of success is l/n. The 

15 random variable that represents the number of units of inventory at any particular 
store may be denoted by JSf$. At step 182, inventory s at each location 24 may be 
estimated by calculating the probability of a location 24 having inventory s using 
Equation (15): 



where S represents the total amount of inventory at all locations 24. Similarly, at step 
184, the probability of demand d at each location 24 may be calculated using 
Equation (16): 



where D represent^ the aggregate demand summed over locations 24, and X D denotes 
the random variable that represents the unit demand at a particular location 24. 



20 




(15) 



25 




(16) 
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The expected number of unrealized sales E(M) may be calculated at step 186 
using Equation (17): 



s D 



S D 

= YBnp(S,s±y Y Bnp(D 9 dA)(d-s) 



-z 



s) 



(17) 



To efficiently implement computation of unrealized sales E(M) on system 10, 
different numerical approximations schemes may be used, depending on the value 
ranges of the input parameters. In the following, several approximation schemes are 
10 described that can be applied according to the value ranges of jD, S, and n. 

The binomial distribution as expressed by Equation (1 8): 

Bnp(k y n,p) = ^p k (l- P y- k . (18) 

may be approximated by the Poisson distribution for a sufficiently large n, a 
sufficiently small p, and moderately sized np 9 as expressed by Equation (19): 

15 Bnp(k;n iP ) «— — , (19) 

where X = np. This can be applied, for example, to the computation of E(M) at step 
182, if np>l0. Thus, steps 182 through 186 may be performed using a Poisson 
approximation to a binomial distribution by computing the probability of a location 24 
having an inventory s or demand d using Equation (19). 



20 



At step 186, expected number E(M) may be determined using Equation (20): 
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(20) 



Alternatively, the computation in Equation (17) may be performed by using an 
incomplete beta-function. The inner sum of Equation (17) may be denoted by and 
Equations (21) through (28) may be used to describe the steps to transform J into a 
5 form that may be efficiently computed using a standard procedure for the incomplete 
beta-function. 

7= Y Bnp(D y d±)(d-s)= V fj\V ( l-V^(J-,) (21) 
Probabilities p and q are defined using Equations (22): 



1 

P = - 
n 



(22) 



10 



q=\-p 



/may then be expressed by Jl and J2, as shown by Equation (23): 




s — J\—J2 



where 




(23) 



Expression 



d maybe substituted by Equation (24): 



15 




(24) 



Furthermore, Jl may be described by Equation (25): 
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5 



* = CpW:}y-Y-' (25) 



where: 

D'=D-1. 



To compute J, the components Jl and J2 and Equation (26) may be used: 

^(py^'^/^wG-^+l) (26) 

where / x (c6) is an incomplete beta function given by Equation (27), 

10 lXa ' b)= it^^' l{l ~ trdt (27) 



'0 

00 



where B(a,b)= jt a - l (\-t) b - 1 di (28) 
0 



At step 188, the aggregate sales forecast is computed according to the 
expected number of unrealized sales. An aggregate sales forecast at a successor state 

15 52 is calculated by subtracting the expected sales from the aggregate inventory at a 
predecessor state 52. The demand does not take into account unrealized sales. Thus, 
the expected number of unrealized sales may be subtracted from the forecasted 
demand to account for unrealized sales, which may yield a more accurate price 
schedule. After the forecast is adjusted, the method is terminated. 

20 The present invention may efficiently generate an optimized price schedule by 

using dynamic programming. In dynamic programming, transition graph 50 with 
paths representing possible price schedules is generated, and an optimal path of the 
transition graph 50 is selected in order to determine an optimized price schedule. The 
present invention may also improve the efficiency of the optimization by using 

25 quantized dynamic programming, which involves quantifying values associated with 
transition graph 50. Quantizing the values reduces the complexity of transition graph 
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50, which may improve the processing time and power required to determine an 
optimal path of transition graph 50. In addition, the present invention may use an 
improved calculation of elasticity in order to increase the accuracy of the 
optimization. Moreover, the present invention may take into account an unrealized 
5 sale that occurs at one of many locations, which may improve the accuracy of the 
optimal path. 

Although the present invention has been described with several embodiments, 
a myriad of changes, variations, alterations, transformations, and modifications may 
be suggested to one skilled in the art, and it is intended that the present invention 
10 encompass such changes, variations, alterations, transformations, and modifications as 
fall within the scope of the appended claims. 
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WHAT IS CLAIMED IS: 

1 . A method for generating a price schedule, comprising: 
generating a transition graph comprising a plurality of paths, each path 
comprising a plurality of states, each state having a price value, an inventory value, 
5 and a state value, the transition graph being generated by repeating the following for a 
plurality of stages until a final stage is reached: 

determining the price value of a successor state; 
calculating the inventory value of the successor state using the price 
value and the inventory value of a predecessor state; and 
10 calculating the state value of the successor state using the price value 

and the inventory value of the predecessor state; 

selecting an optimal path according to the state values of the states; and 
determining a price schedule from the optimal path. 

15 2. The method of Claim 1, further comprising quantizing the inventory 

value of each successor state. 

3. The method of Claim 1, further comprising quantizing the price value 
of each successor state. 

20 

4. The method of Claim 1, wherein selecting the optimal path according 
to the state values comprises: 

determining a state at the final stage having an optimal state value; and 
determining a path comprising a state of an initial stage and the state having 
25 the optimal state value. 

5. The method of Claim 1, further comprising eliminating a successor 
state in response to a constraint. 
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6. The method of Claim 1, further comprising: 
computing an elasticity curve; and 

computing the inventory value of each successor state using the elasticity 

curve. 

5 

7 . The method of Claim 1 , wherein: 
each state has a certainty value; and 

selecting the optimal path comprises determining a state at the final stage 
having a certainty value of a predetermined value. 

10 

8. The method of Claim 1, further comprising: 
defining a plurality of locations; 

estimating a demand forecast for the locations; 
calculating an expected number of unrealized sales at each location; 
15 adjusting the demand forecast in response to the expected number; 

determining a sales forecast from the demand forecast; 

and 

adjusting the inventory value of the successor state in response to the sales 
forecast. 
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9. A system for generating a price schedule, comprising: 

a transition graph generator operable to generate a transition graph comprising 
a plurality of paths, each path comprising a plurality of states, each state having a 
price value, an inventory value, and a state value, the transition graph generator 
5 operable to generate the transition graph by repeating the following for a plurality of 
stages until a final stage is reached: 

determining the price value of a successor state; 
calculating the inventory value of the successor state using the price 
value and the inventory value of a predecessor state; and 
10 calculating the state value of the successor state using the price value 

and the inventory value of the predecessor state; and 

an optimizer coupled to the transition graph generator and operable to: 

select an optimal path according to the state values of the states; and 
determine a price schedule from the optimal path. 

15 

10. The system of Claim 9, wherein the transition graph generator is 
operable to quantize the inventory value of each successor state. 

1 1 . The system of Claim 9, wherein the transition graph generator is 
20 operable to quantize the price value of each successor state. 



12. The system of Claim 9, wherein the optimizer is operable to select the 
optimal path according to the state values by: 

determining a state at the final stage having an optimal state value; and 
25 determining a path comprising a state of an initial stage and the state having 

the optimal state value. 



30 



13. The system of Claim 9, wherein the transition graph generator is 
operable to eliminate a successor state in response to a constraint. 
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14. The system of Claim 9, further comprising an elasticity module 
coupled to the transition graph generator and operable to compute an elasticity curve, 
the transition graph generator operable to compute the inventory value of each 
successor state using the elasticity curve. 

5 

15. The system of Claim 9, wherein: 
each state has a certainty value; and 

the optimizer is operable to select the optimal path by determining a state at 
the final stage having a certainty value, of a predetermined value. 

10 

16. The system of Claim 9, wherein the transition graph generator is 
operable to: 

define a plurality of locations; 
estimate a demand forecast for the locations; 
1 5 calculate an expected number of unrealized sales at each location; 

adjust the demand forecast in response to the expected number; 
determine a sales forecast from the demand forecast; 

and 

adjust the inventory value of the successor state in response to the sales 
20 forecast. 
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17. Logic for generating a price schedule, the logic encoded in media and 
when executed operable to: 

generate a transition graph comprising a plurality of paths, each path 
comprising a plurality of states, each state having a price value, an inventory value, 
5 and a state value, the transition graph being generated by repeating the following for a 
plurality of stages until a final stage is reached: 

determining the price value of a successor state; 
calculating the inventory value of the successor state using the price 
value and the inventory value of a predecessor state; and 
10 calculating the state value of the successor state using the price value 

and the inventory value of the predecessor state; 

select an optimal path according to the state values of the states; and 
determine a price schedule from the optimal path. 

15 18. The logic of Claim 17, further operable to quantize the inventory value 

of each successor state. 

19. The logic of Claim 17, further operable to quantize the price value of 
each successor state. 

20 

20. The logic of Claim 17, further operable to select the optimal path 
according to the state values by: 

determining a state at the final stage having an optimal state value; and 
determining a path comprising a state of an initial stage and the state having 
25 the optimal state value. 

21. The logic of Claim 17, further operable to eliminate a successor state 
in response to a constraint. 
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22. The logic of Claim 1 7, further operable to: 
compute an elasticity curve; and 

compute the inventory value of each successor state using the elasticity curve. 



5 23. The logic of Claim 17, wherein: 

each state has a certainty value; and 

wherein the logic is further operable to select the optimal path by determining 
a state at the final stage having a certainty value of a predetermined value. 

1 0 24. The logic of Claim 1 7, further operable to: 

define a plurality of locations; 

estimate a demand forecast for the locations; 

calculate an expected number of unrealized sales at each location; 

adjust the demand forecast in response to the expected number; 
15 determine a sales forecast from the demand forecast; 

and 

adjust the inventory value of the successor state in response to the sales 
forecast. 
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25. A system for generating a price schedule, comprising: 
means for generating a transition graph comprising a plurality of paths, each 
path comprising a plurality of states, each state having a price value, an inventory 
value, and a state value, the transition graph being generated by repeating the 
5 following for a plurality of stages until a final stage is reached: 
determining the price value of a successor state; 
calculating the inventory value of the successor state using the price 
value and the inventory value of a predecessor state; and 

calculating the state value of the successor state using the price value 
1 0 and the inventory value of the predecessor state; and 

means for selecting an optimal path according to the state values of the states 
and for determining a price schedule from the optimal path. 
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26. A method for generating a price schedule, comprising: 
generating a transition graph comprising a plurality of paths, each path 
comprising a plurality of states, each state having a price value, an inventory value, 
and a state value, the transition graph being generated by repeating the following for a 
5 plurality of stages until a final stage is reached: 
computing an elasticity curve; 
determining the price value of a successor state; 
calculating the inventory value of the successor state using the 
elasticity curve, the price value, and the inventory value of a predecessor state; 
10 adjusting the inventory value of the successor state by defining a 

plurality of locations, calculating an expected number of unrealized sales at each 
location, and adjusting the inventory value of the successor state in response to the 
expected number; 

quantizing the inventory value and the price value of the successor 

15 state; and 

calculating the state value of the successor state using the price value 
and the inventory value of the predecessor state; 

selecting an optimal path according to the state values of the states by 
determining a state at the final stage having an optimal state value and determining a 
20 path comprising a state of an initial stage and the state having the optimal state value; 
and 

determining a price schedule from the optimal path. 
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27. A method for computing an elasticity curve, comprising: 
selecting a demand model having a plurality of variables; 
receiving a plurality of values for each variable; 

defining a plurality of filter sets, each filter set operable to restrict the values 
5 for at least one variable; 

determining an elasticity curve for each filter set by: 

filtering the values for at least one variable using the filter set; and 
calculating the elasticity curve from the filtered values by performing a 
regression analysis using the demand model as a regression equation; 
1 0 measuring a quality value for each elasticity curve; and 

selecting an optimal elasticity curve according to the quality values. 

28. The method of Claim 27, wherein the variables comprise: 
a dependent variable comprising a demand variable; and 

15 a plurality of independent variables comprising a price variable and time 

variables. 



29. The method of Claim 27, wherein: 

the variables comprise a dependent variable and a plurality of independent 
20 variables; and 

determining the elasticity curve comprises using the demand model as a 
regression equation of the dependent variable over the independent variables. 
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30. . The method of Claim 27, wherein: 

the values are associated with a plurality of products; and 
detemiining the elasticity curve for each filter set comprises: 

determining an elasticity curve for each product using the values 
5 associated with the product; 

measuring a quality value for each elasticity curve; 

determining an unsatisfactory elasticity curve according to the quality 

values; and 

eliminating the values associated with the unsatisfactory elasticity 

10 curve. 

3 1 . The method of Claim 27, wherein: 

the values are associated with a plurality of products; and 
determining the elasticity curve for each filter set comprises: 
15 determining an elasticity curve for each product using the values 

associated with the product; 

calculating an elasticity value from each elasticity curve; 

determining an unsatisfactory elasticity value; and 

eliminating the values associated with the unsatisfactory elasticity 

20 value. 

32. The method of Claim 27, wherein the variables comprise an 
independent variable comprising a promotional variable. 

25 33. The method of Claim 27, wherein the variables comprise an 

independent variable comprising a seasonality index variable. 
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34. A system for computing an elasticity curve, comprising: 

a database operable to store a demand model having a plurality of variables, a 
plurality of values for each variable, and a plurality of filter sets, each filter set 
operable to restrict the values for at least one variable; and 
5 a server coupled to the database and operable to: 

determine an elasticity curve for each filter set by filtering the values 
for at least one variable using the filter set, and calculating the elasticity curve from 
the filtered values by performing a regression analysis using the demand model as a 
regression equation; 
1 0 measure a quality value for each elasticity curve; and 

select an optimal elasticity curve according to the quality values. 

35. The system of Claim 34, wherein the variables comprise: 
a dependent variable comprising a demand variable; and 

15 a plurality of independent variables comprising a price variable and a time 

variable. 



36. The system of Claim 34, wherein: 

the variables comprise a dependent variable and a plurality of independent 
20 variables; and 

the server is operable to perform a regression analysis using the demand model 
as a regression equation of the dependent variable over the independent variables. 
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37. The system of Claim 34, wherein: 

the values are associated with a plurality of products; and 

the server is operable to determine the elasticity curve for each filter set by: 

determining an elasticity curve for each product using the values 
5 associated with the product; 

measuring a quality value for each elasticity curve; 

determining an unsatisfactory elasticity curve according to the quality 

values; and 

eliminating the values associated with the unsatisfactory elasticity 

10 curve. 

38. The system of Claim 34, wherein: 

the values are associated with a plurality of products; and 
the server is operable to determine the elasticity curve for each filter set by: 
15 determining an elasticity curve for each product using the values 

associated with the product; 

calculating an elasticity value from each elasticity curve; 

determining an unsatisfactory elasticity value; and 

eliminating the values associated with the unsatisfactory elasticity 

20 value. 

39. The system of Claim 34, wherein the variables comprise an 
independent variable comprising a promotional variable. 

25 40. The system of Claim 34, wherein the variables comprise an 

independent variable comprising a seasonality index variable. 
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41. Logic for computing an elasticity curve, the logic encoded in media 
and when executed operable to: 

select a demand model having a plurality of variables; 
receive a plurality of values for each variable; 
5 define a plurality of filter sets, each filter set operable to restrict the values for 

at least one variable; 

determine an elasticity curve for each filter set by: 

filtering the values for at least one variable using the filter set; and 
calculating the elasticity curve from the filtered values by performing a 
10 regression analysis using the demand model as a regression equation; 
measure a quality value for each elasticity curve; and 
select an optimal elasticity curve according to the quality values. 

42. The logic of Claim 41 , wherein the variables comprise: 
1 5 a dependent variable comprising a demand variable; and 

a plurality of independent variables comprising a price variable and a time 
variable. 

43. The logic of Claim 41, wherein: 

20 the variables comprise a dependent variable and a plurality of independent 

variables; and 

the logic is further operable to use the demand model as a regression equation 
of the dependent variable over the independent variables. 
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44. The logic of Claim 4 1 , wherein: 

the values are associated with a plurality of products; and 

the logic is further operable to determine the elasticity curve for each filter set 

by: 

5 determining an elasticity curve for each product using the values 

associated with the product; 

measuring a quality value for each elasticity curve; 

determining an unsatisfactory elasticity curve according to the quality 

values; and 

10 eliminating the values associated with the unsatisfactory elasticity 

curve. 

45. The logic of Claim 41, wherein: 
the values are associated with a plurality of products; and 
the logic is further operable to determine the elasticity curve for each filter set 

by: 

determining an elasticity curve for each product using the values 
associated with the product; 

calculating an elasticity value from each elasticity curve; 
determining an unsatisfactory elasticity value; and 
eliminating the values associated with the unsatisfactory elasticity 

value. 

46. The logic of Claim 41, wherein the variables comprise an independent 
25 variable comprising a promotional variable. 

47. The logic of Claim 41, wherein the variables comprise an independent 
variable comprising a seasonality index variable. 



15 



20 
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48. A system for computing an elasticity curve, comprising: 
means for selecting a demand model having a plurality of variables; 
means for receiving a plurality of values for each variable; 
means for defining a plurality of filter sets, each filter set operable to restrict 
5 the values for at least one variable; 

means for determining an elasticity curve for each filter set by: 

filtering the values for at least one variable using the filter set; and 
calculating the elasticity curve from the filtered values by performing a 
regression analysis using the demand model as a regression equation; 
1 0 means for measuring a quality value for each elasticity curve; and 

means for selecting an optimal elasticity curve according to the quality values. 
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49. A method for computing an elasticity curve, comprising: 
selecting a demand model having a plurality of variables, the variables 
comprising a dependent variable comprising a demand variable, the variables 
comprising a plurality of independent variables comprising a price variable and a time 
5 variable; 

receiving a plurality of values for each variable, the values associated with a 
plurality of products; 

defining a plurality of filter sets, each filter set operable to restrict the values 
for at least one variable; 
1 0 determining an elasticity curve for each filter set by: 

filtering the values for at least one variable using the filter set; and 
eliminating the values that are unsatisfactory by: 

determining an elasticity curve for each product using the 
values associated with the product; 
15 measuring a quality value for each elasticity curve; 

determining an unsatisfactory elasticity curve according to the 

quality values; and 

eliminating the values associated with the unsatisfactory 

elasticity curve; and 

20 calculating the elasticity curve from the remaining values -by 

performing a regression analysis using the demand model as a regression equation of 
the dependent variable over the independent variables; 

measuring a quality value for each elasticity curve; and 

selecting an optimal elasticity curve according to the quality values. 
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50. A method for determining a sales forecast, comprising: 
defining a plurality of locations; 

estimating an inventory at each location; 
estimating a demand at each location; 
5 calculating an expected number of unrealized sales at each location using a 

difference between the demand at the location and the inventory at the location; and 
determining a sales forecast in response to the expected number. 

5 1 . The method of Claim 50, wherein: 

10 estimating the inventory at each location comprises randomly populating the 

locations with a plurality of inventory units; and 

estimating the demand at each location comprises randomly populating the 
locations with a plurality of demand units. 



15 52. The method of Claim 50, wherein: 

estimating the inventory at each location comprises calculating a probability of 
each location receiving a number of inventory units according to a binomial 
distribution; and 

estimating the demand at each location comprises calculating a probability of 
20 each location receiving a number of demand units according to the binomial 
distribution. 



53. The method of Claim 50, wherein: 

estimating the inventory at each location comprises calculating a probability of 
25 each location receiving a number of inventory units according to an incomplete beta- 
function; and 

estimating the demand at each location comprises calculating a probability of 
each location receiving a number of demand units according to the incomplete beta- 
function. 
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54. A system for determining a sales forecast, comprising: 
a database operable to store a plurality of definitions defining a plurality of 
locations; and 

a server coupled to the database and operable to: 

estimate an inventory at each location; 

estimate a demand at each location; 

calculate an expected number of unrealized sales at each location using 
a difference between the demand at the location and the inventory at the location; and 
determine a sales forecast in response to the expected number. 



55. The system of Claim 54, wherein the server is operable to: 
estimate the inventory at each location by randomly populating the locations 
with a plurality of inventory units; and 

estimate the demand at each location by randomly populating the locations 
1 5 with a plurality of demand units. 



56. The system of Claim 54, wherein the server is operable to: 
estimate the inventory at each location by calculating a probability of each 
location receiving a number of inventory units according to a binomial distribution; 
20 and 

estimate the demand at each location by calculating a probability of each 
location receiving a number of demand units according to the binomial distribution. 



57. The system of Claim 54, wherein the server is operable to: 
25 estimate the inventory at each location by calculating a probability of each 

location receiving a number of inventory units according to an incomplete beta- 
function; and 

estimate the demand at each location by calculating a probability of each 
location receiving a number of demand units according to the incomplete beta- 
30 function. 
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58. Logic for determining a sales forecast, the logic encoded in media and 
when executed operable to: 

define a plurality of locations; 

estimate an inventory at each location; 
5 estimate a demand at each location; 

calculate an expected number of unrealized sales at each location using a 
difference between the demand at the location and the inventory at the location; and 

determine a sales forecast in response to the expected number. 

10 59. The logic of Claim 58, further operable to: 

estimate the inventory at each location by randomly populating the locations 
with a plurality of inventory units; and 

estimate the demand at each location by randomly populating the locations 
with a plurality of demand units. 

15 

60. The logic of Claim 58, farther operable to: 

estimate the inventory at each location by calculating a probability of each 
location receiving a number of inventory units according to a binomial distribution; 
and 

20 estimate the demand at each location by calculating a probability of each 

location receiving a number of demand units according to the binomial distribution. 

61. The logic of Claim 58, further operable to: 

estimate the inventory at each location by calculating a probability of each 
25 location receiving a number of inventory units according to an incomplete beta- 
function; and 

estimate the demand at each location by calculating a probability of each 
location receiving a number of demand units according to the incomplete beta- 
function. 
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62. m A system for determining a sales forecast, comprising: 
means for defining a plurality of locations; 
means for estimating an inventory at each location; 
means for estimating a demand at each location; 
5 means for calculating an expected number of unrealized sales at each location 

using a difference between the demand at the location and the inventory at the 
location; and 

means for determining a sales forecast in response to the expected number. 
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63. A method for determining a sales forecast, comprising: 
defining a plurality of locations; 

estimating the inventory at each location by calculating a probability of each 
location receiving a number of inventory units according to an incomplete beta- 
5 function; 

estimating the demand at each location by calculating a probability of each 
location receiving a number of demand units according to the incomplete beta- 
function; 

calculating an expected number of unrealized sales at each location using a 
10 difference between the demand at the location and the inventory at the location; and 
determining a sales forecast in response to the expected number. 
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64. A method for generating a price schedule, comprising: 
generating a transition graph comprising a plurality of paths, each path 
comprising a plurality of states, each state having a plurality of values comprising a 
state value, the transition graph being generated by repeating the following for a 
5 plurality of stages until a final stage is reached; 

calculating the values of a successor state using the values of a 
predecessor state; and 

quantizing the values of each successor state; 
selecting an optimal path according to the state values of the states; and 
1 0 determining a price schedule from the optimal path. 



65. The method of Claim 64, wherein the values comprise a price value. 

66. The method of Claim 64, wherein the values comprise an inventory 

15 value. 



67. The method of Claim 64, wherein selecting the optimal path according 
to the state values comprises: 

determining a state at the final stage having an optimal state value; and 
20 determining a path comprising a state of an initial stage and the state having 

the optimal state value. 



68. The method of Claim 64, further comprising eliminating a successor 
state in response to a constraint. 

25 

69. The method of Claim 64, further comprising: 
computing an elasticity curve; and 

computing an inventory value of each successor state using the elasticity 

curve. 



30 
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70. The method of Claim 64, wherein: 
each state has a certainty value; and 

selecting the optimal path comprises determining a state at the final stage 
having a certainty value of a predetermined value. 

5 

7 1 . The method of Claim 64, further comprising: 
defining a plurality of locations; 

calculating an expected number of unrealized sales at each location; and 
adjusting a value of the successor state in response to the expected number. 
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